## Unidad Aritmética y Lógica.

La unidad aritmética y lógica (ALU – Arithmetic Logic Unit) es la encargada de realizar las operaciones aritméticas (suma y resta) y lógicas básicas (AND, OR, NAND, NOR y NOT). Esta unidad es la que realiza prácticamente el procesamiento en un sistema de cómputo. Para realizar el diseño de la ALU partiremos del análisis de un circuito sumador y restador completo de un bit, para después generalizarlo para "n" bits. Dos esquemas son analizados para este circuito:

- Sumador y restador con acarreo en cascada.
- > Sumador y restador con acarreo anticipado.

## Análisis de un circuito sumador y restador con acarreo en cascada.

Se parte del análisis clásico, aquí en primera instancia, se genera la tabla de verdad para un sumador completo de 1 bit. Esta tabla contiene las entradas del bit  $A_i$  a sumar con el bit  $B_i$  y el acarreo de entrada  $C_i$ . Como salidas se tiene el resultado de la suma  $S_i$  y el siguiente acarreo  $C_{i+1}$  generado a ser tomado en cuenta por el bit más significativo siguiente o MSB (Most Significant Bit), como se muestra en la tabla 1.

Donde: i = 0,1,...,n-1n=número de bits del circuito sumador

| $A_{i}$ | $B_{i}$ | $C_{i}$ | $S_{i}$ | $C_{i+1}$ |
|---------|---------|---------|---------|-----------|
| 0       | 0       | 0       | 0       | 0         |
| 0       | 0       | 1       | 1       | 0         |
| 0       | 1       | 0       | 1       | 0         |
| 0       | 1       | 1       | 0       | 1         |
| 1       | 0       | 0       | 1       | 0         |
| 1       | 0       | 1       | 0       | 1         |
| 1       | 1       | 0       | 0       | 1         |
| 1       | 1       | 1       | 1       | 1         |

Tabla 1 Sumador completo de 1 bit.

Para obtener la ecuación de salida de  $S_i$  se utiliza una compuerta que de forma natural suma bits. Se trata de la compuerta lógica OR exclusiva (XOR), cuya tabla de verdad se muestra en la tabla 2.

| Α | В | XOR |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |
| 1 | 1 | 0   |

Tabla 2 Tabla de verdad de la compuerta XOR

La ecuación para la salida *XOR* se muestra a continuación:

$$XOR = A\overline{B} + \overline{A}B = A \oplus B \tag{1}$$

Por lo tanto, la ecuación para  $S_i$  queda así:

$$S_i = A_i \oplus B_i \oplus C_i \tag{2}$$

Para obtener la ecuación de salida simplificada de  $C_{i+1}$  es posible manejar diferentes esquemas, el más común es usar un mapa de Karnaugh como se muestra en la figura 1.



Figura 1 Mapa de Karnaugh para obtener la ecuación del acarreo.

Aplicando el procedimiento de simplificación se tiene la ecuación 3.

$$C_{i+1} = A_i C_i + B_i C_i + A_i B_i$$
 (3)

Empleando las ecuaciones 2 y 3 es posible generar un sumador de n bits conectando los acarreos en cascada. Aunque este esquema no es el mejor, es el más simple e intuitivo. En la figura 2 se muestra un ejemplo de conexión para un sumador de 4 bits usando los acarreos en cascada.



Figura 2 Circuito Sumador de 4 bits

En la figura 3 se muestra la operación de suma para 4 bits.



Figura 3 Operación de suma con 4 bits

En la operación de suma de la figura 3 el acarreo inicial  $C_0$  debe ser cero. Usando las ecuaciones 2 y 3 podemos escribir las ecuaciones para cada uno de los bits del circuito sumador de la figura 2.

$$S_0 = A_0 \oplus B_0 \oplus C_0 \tag{4}$$

$$C_1 = A_0 C_0 + B_0 C_0 + A_0 B_0 \tag{5}$$

$$S_{1} = A_{1} \oplus B_{1} \oplus C_{1}$$

$$C_{2} = A_{1}C_{1} + B_{1}C_{1} + A_{1}B_{1}$$

$$S_{2} = A_{2} \oplus B_{2} \oplus C_{2}$$

$$C_{3} = A_{2}C_{2} + B_{2}C_{2} + A_{2}B_{2}$$

$$S_{3} = A_{3} \oplus B_{3} \oplus C_{3}$$

$$C_{4} = A_{3}C_{3} + B_{3}C_{3} + A_{3}B_{3}$$

$$(11)$$

El circuito de la figura 2 sólo puede realizar sumas, de números de 4 bits. Como se desea realizar un circuito sumador y restador, entonces es necesario analizar una operación de resta. Para ello se propone realizar la resta a través de la suma de la siguiente forma:

$$r = A - B = A + (-B)$$
 (12)

La ecuación 12 nos dice que la resta es una suma donde necesitamos colocar a B en complemento a dos para representarlo en forma negativa.

Como ejemplo, vamos a suponer que A=5 y B=3, por lo que la resta estaría dada por:

$$r = A - B = A + (-B) = 5 + (-3) = 2$$
 (13)

De esta manera, se utiliza un circuito sumador para realizar una sustracción y los operandos son los que incorporan el bit de signo. Si la operación de sustracción se realiza en binario empleando un sumador de 4 bits, es necesario poseer el equivalente binario de los números 5 y -3. El equivalente binario del número 5 es 0101. Para representar el binario de -3 es necesario utilizar la representación en complemento a dos. Esta se obtiene colocando el número binario normal, después obtenemos el complemento a uno, que es simplemente negar los bits del número, y posteriormente sumar 1 al resultado del complemento a uno. Esto lo podemos observar en la figura 4.



Figura 4 Complemento a dos del número 3

La operación de la ecuación 13 queda como se muestra en la figura 5.

La operación anterior es equivalente a:

Figura 5 Operación de resta

Como podemos observar en la figura 5 la operación de resta es en realidad una suma con dos modificaciones al operando  $B_i$  o sustraendo. Estas modificaciones son la negación o complemento a uno y posteriormente la suma de uno al complemento a uno. Este uno que sumamos al complemento a uno, lo podemos colocar en el acarreo inicial  $C_0$ . Además de las modificaciones al sustraendo, debemos definir una señal de control que permita seleccionar entre las dos operaciones (suma o resta) a realizar con los datos. Esta señal la llamaremos Binvert y su función se muestra en la tabla 3.

| Binvert | Operación |
|---------|-----------|
| 0       | Suma      |
| 1       | Resta     |

Tabla 3 Señal de selección de operación

Con esta señal de control ya podemos realizar las modificaciones al circuito sumador de la figura 2 para convertirlo en un circuito sumador y restador. La primer modificación al operando  $B_i$  o sustraendo es obtener su complemento a uno. Esto lo obtenemos con un circuito inversor, pero este circuito solo debe negar a  $B_i$  cuando se seleccione la operación de resta, en el caso de que se quiera realizar la operación de suma, **el operando no debe ser negado**. Esta selección se obtiene con un circuito multiplexor de dos entradas, una salida y un selector, donde la entrada 0 es  $B_i$  sin negar y la entrada 1 es  $\overline{B_i}$ . El selector es la señal de control Binvert. Estas modificaciones se muestran en la figura 6.



Figura 6 Circuito sumador y restador

Analicemos la figura 6. Si queremos realizar una operación de suma colocamos en la señal Binvert un cero con esto seleccionamos la entrada 0 del multiplexor permitiendo a  $B_i$  pasar a la entrada  $EB_i$  del circuito sumador. Al mismo tiempo el acarreo inicial  $C_0$  es colocado en cero obteniendo una operación de suma. Por el contrario, si queremos realizar una operación de resta colocamos en la señal Binvert un uno, con esto seleccionamos la entrada 1 del multiplexor permitiendo a  $\overline{B_i}$  (complemento a uno) pasar a la entrada  $EB_i$  del circuito sumador. Al mismo tiempo el acarreo inicial  $C_0$  es iniciado con uno, obteniendo la segunda modificación del operando  $B_i$  y de esta forma el complemento a dos y la operación de resta.

Finalmente analicemos el circuito multiplexor de la figura 7, que es el circuito usado en la figura 6. Este es un multiplexor de dos entradas una salida y un selector.



Figura 7 Multiplexor de dos entradas, una salida y un selector

La ecuación de salida del multiplexor mostrado en la figura 7 es la siguiente:

$$SAL = E_0 \overline{SEL} + E_1 SEL \tag{14}$$

En el caso del circuito sumador y restador mostrado en la figura 6, la entrada  $E_0$  es la entrada  $B_i$ , la entrada  $E_1$  es la entrada  $\overline{B_i}$ , el selector es la señal Binvert y la salida del multiplexor es la señal  $EB_i$ . Con estas equivalencias la ecuación 14 se puede reescribir como se muestra a continuación:

$$EB_{i} = B_{i} \overline{Binvert} + \overline{B_{i}} Binvert \tag{15}$$

Al observar la ecuación 15 nos damos cuenta de que se trata de una operación XOR entre la señal  $B_i$  y Binvert de acuerdo a la ecuación 1. Es decir, la ecuación 15 la podemos reescribir como:

$$EB_i = B_i \oplus Binvert$$
 (16)

Con esto nos damos cuenta que el multiplexor que estamos utilizando es en realidad una operación XOR. Por lo tanto, podemos sustituir el multiplexor mostrado en la figura 6, tal como se muestra en la figura 8.



Figura 8 Circuito sumador y restador

Finalmente las ecuaciones para el circuito sumador y restador son una modificación de las ecuaciones 2 y 3, donde se agrega la parte de la compuerta XOR. Esto nos da como resultado las ecuaciones 17 y 18.

$$S_i = A_i \oplus EB_i \oplus C_i \tag{17}$$

$$C_{i+1} = A_i C_i + E B_i C_i + A_i E B_i$$
 (18)

Las ecuaciones 16, 17 y 18 son las ecuaciones a programar en el dispositivo lógico programable usando un lenguaje de descripción de hardware como VHDL, el ambiente de desarrollo a usar para este programa es ISE WEB PACK de la compañía Xilinx. De la figura 8 podemos observar que las señales  $A_0, \ldots, A_3$ ,  $B_0, \ldots, B_3$ ,  $C_0$  y Binvert, son señales de entrada. Las señales  $S_0, \ldots, S_3$  y  $C_4$  son señales de salida. El tener la señal  $C_0$  independiente de Binvert nos permite poder conectar varios componentes en cascada para formar un circuito sumador y restador de mayor cantidad de bits.

Analicemos el desempeño del circuito de la figura 8. Una vez que se tiene el valor en la señal  $EB_i$  se necesitan de 2 retardos de propagación para obtener el valor del acarreo  $C_1$ . Posteriormente el valor del acarreo  $C_2$  se obtiene después de 4 retardos de propagación (2 de  $C_1$  + 2 de  $C_2$ ), el valor del acarreo  $C_3$  se obtiene después de 6 retardos de propagación (2 de  $C_1$  + 2 de  $C_2$  + 2 de  $C_3$ ) y el valor del acarreo  $C_4$  se obtiene después de 8 retardos de propagación (2 de  $C_1$  + 2 de  $C_2$  + 2 de  $C_3$  + 2 de  $C_4$ ). En general para un

circuito sumador y restador de n bits el valor del acarreo  $C_n$  se obtiene después de 2n retardos de propagación. Si estamos hablando que la ALU es el núcleo de procesamiento del procesador, este retardo afecta significativamente el desempeño de la ALU y por lo tanto del procesador. Este esquema se conoce como circuito sumador y restador con acarreo en cascada.

## Análisis de un circuito sumador y restador con acarreo anticipado.

Este circuito elimina el retardo de 2n en el bit de acarreo  $C_n$  del circuito sumador y restador con acarreo en cascada. Para entender cómo se elimina dicho retardo analizaremos la ecuación de salida para  $C_{i+1}$  generada del mapa de Karnaugh mostrado en la figura 1, pero ahora agrupando como se muestra en la figura 9.



Figura 9 Mapa de Karnaugh para obtener la ecuación del acarreo.

Aplicando el procedimiento de simplificación se tiene la ecuación 19.

$$C_{i+1} = A_i B_i + A_i \overline{B_i} C_i + \overline{A_i} B_i C_i$$

$$C_{i+1} = A_i B_i + C_i (A_i \overline{B_i} + \overline{A_i} B_i)$$

$$C_{i+1} = A_i B_i + C_i (A_i \oplus B_i)$$

$$(19)$$

Para analizar la ecuación anterior definiremos las ecuaciones mostradas en 20.

$$P_i = A_i \oplus B_i$$

$$G_i = A_i B_i$$
(20)

Con las ecuaciones anteriores la ecuación 19 se reescribe como se muestra en la ecuación 21.

$$C_{i+1} = G_i + C_i P_i (21)$$

Si se desarrolla la ecuación 21 para un sumador de 4 bits tenemos los acarreos de la ecuación 22.

$$C_{0} = acarreo\_inicial$$

$$C_{1} = G_{0} + C_{0}P_{0}$$

$$C_{2} = G_{1} + C_{1}P_{1} = G_{1} + (G_{0} + C_{0}P_{0})P_{1}$$

$$C_{2} = G_{1} + G_{0}P_{1} + C_{0}P_{0}P_{1}$$

$$C_{3} = G_{2} + C_{2}P_{2} = G_{2} + (G_{1} + G_{0}P_{1} + C_{0}P_{0}P_{1})P_{2}$$

$$C_{3} = G_{2} + G_{1}P_{2} + G_{0}P_{1}P_{2} + C_{0}P_{0}P_{1}P_{2}$$

$$C_{4} = G_{3} + C_{3}P_{3} = G_{3} + (G_{2} + G_{1}P_{2} + G_{0}P_{1}P_{2} + C_{0}P_{0}P_{1}P_{2})P_{3}$$

$$C_{4} = G_{3} + G_{2}P_{3} + G_{1}P_{2}P_{3} + G_{0}P_{1}P_{2}P_{3} + C_{0}P_{0}P_{1}P_{2}P_{3}$$

$$(22)$$

De los acarreos de la ecuación 22 se puede observar lo siguiente:

Al realizar la sustitución en cada ecuación  $C_{i+1}$  por el acarreo  $C_i$ , todas las ecuaciones resultantes dependen del acarreo inicial  $C_0$ .

- ➤ Se tiene un retardo de propagación constante de 2td para todos los acarreos.
- Se puede obtener una ecuación que genere las ecuaciones para cada bit de acarreo  $C_{i+1}$ . Para un sumador de n bits, donde i = 0,1,2,...,n-1 se obtiene la ecuación 23.

$$C_{i+1} = G_i + \sum_{j=0}^{i-1} G_j \prod_{k=j+1}^{i} P_k + C_0 \prod_{l=0}^{i} P_l$$
 (23)

Por lo tanto las ecuaciones completas para el sumador y restador con acarreo anticipado son:

$$EB_{i} = B_{i} \oplus Binvert$$

$$P_{i} = A_{i} \oplus EB_{i}$$

$$G_{i} = A_{i} EB_{i}$$

$$S_{i} = A_{i} \oplus EB_{i} \oplus C_{i}$$

$$C_{i+1} = G_{i} + \sum_{j=0}^{i-1} G_{j} \prod_{k=j+1}^{i} P_{k} + C_{0} \prod_{l=0}^{i} P_{l}$$
(24)